<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
  </head>
  <body>
    <!-- 1. 定义一个根标签,未来将利用react动态创建的元素插入到这个根标签中,从而渲染到页面上 -->
    <div id="root"></div>

    <!-- 2. 引入react.js和react-dom.js-->
    <script src="./js/react.development.js"></script>
    <script src="./js/react-dom.development.js"></script>
    <!-- 引入babel是为了让babel帮我们编译jsx -->
    <script src="./js/babel.js"></script>

    <!-- 3. 根据需求,先创建虚拟dom -->
    <!-- 加了type属性,则表示这个script标签的代码需要被babel编译 -->
    <script type="text/babel">
      // 假设这个对象就是从服务器拿回来的用户信息
      const user = {
        name: '龙夏林',
        hobby: '女',
        sex: '妖',
      }
      // 通过插值表达式{}来插入数据.插值表达式中可以直接解析js
      const element = (
        <div>
          <h1>首页</h1>
          <p>欢迎您: {user.name}</p>
          <p>爱好: {user.hobby}</p>
          <p>性别: {user.sex}</p>
        </div>
      )

      //   4. 根据第三步已经创建出来的虚拟dom,生成真实dom,并插入到root中最终渲染到页面上
      ReactDOM.createRoot(document.getElementById('root')).render(element)
    </script>
  </body>
</html>
